

### **ZEN2044F**

### PROGRAMMABLE UNIVERSAL COUNTER

#### **DESCRIPTION**

The ZEN2044F is a 24bit x 4ch. programmable universal counter LSI. The ZEN2044F can count phase-shifted pulse signals or up/down pulse signals generated from rotary encoders or linear scales.

Since the counter response speed is as high as 33MHz(MAX), the ZEN2044F can be used in a variety of applications required high speed counting, including digital servo controls and precision measurements. As to command sets, the ZEN2044F has a compatibility with the ZEN2011P.

The ZEN2044F can also monitor input signals and detect any abnormal input accompanied with noise or other disturbances, so that the reliability of counted values are secured.

#### 1. Features

24bit binary up/down counter x 4ch.

Counter response speed:

33MHz(MAX)(CLK fo=33MHz at 50% duty)

Input frequency of count pulse

Two phase-shifted pulse signal input:

DC-8.25MHz (less than fo x 1/4)

Up/down pulse signal input:

DC-16.5MHz (less than fo x 1/2)

Direction recognition for up/down count

Abnormal input detection circuit

Preload register for the up/down counter

Latch register for the up/down counter

Coincidence detection between reference value and count value

Counter operation mode

Quad/double/single edge evaluation(for two phase-shifted signal / single pulse signal)

Counter direction selection

Count clear control: synchronous/asynchronous

#### Command mode

#### Mode 0:

Each channel has one comparator for coincidence detection

Each channel has one port for user input

#### Mode 1:

Each channel has two comparators for coincidence detection

Each channel has no port for user input

Logical sum output of coincidence detections available

Interrupt output under some conditions available

#### 8bit data bus

Low power CMOS technology

TTL level compatible input

Single 5V power supply

100 pin QFP

#### Note ) In following chapters;

"n" corresponds to a number of the channel (0-3).

"\*" stands for "Don't care".



#### 2. Block diagram



## 3. Pin description

Table 1

| Name                                           | No.                                    | I/O | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------------------------------------|----------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EXTA0<br>EXTA1<br>EXTA2<br>EXTA3               | 6<br>53<br>71<br>86                    | 0   | The function of this output depends on the command mode. In Mode 0, $\overline{\text{EXTA}n}$ outputs the equal signal $A(\overline{\text{EQA}n})$ . In Mode 1, one of the following three signals can be selected:  -The equal signal $A(\overline{\text{EQA}n})$ .  -The logical sum( $\overline{\text{EQA}n} + \overline{\text{EQB}n}$ ) of the equal signal $A(\overline{\text{EQA}n})$ and the equal signal $B(\overline{\text{EQB}n})$ .  -The hold equal signal $A(\overline{\text{INTEQA}n})$ . |
| CLK                                            | 67                                     | I   | The CLK synchronizes the internal circuit operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| RESET                                          | 16                                     | I   | The RESET initializes the up/down counter, the phase discrimination circuit, the command register and the status register.                                                                                                                                                                                                                                                                                                                                                                              |
| AD/CE0<br>AD/CE1<br>AD/CE2<br>AD/CE3<br>DRCTCE | 26<br>27<br>28<br>29                   | I   | The function of these pins depends on the DRCTCE. If DRCTCE="1", they are all treated as signals for enabling the channel directly. If DRCTCE="0",AD/CE3 and AD/CE2 are the chip enable pins and AD/CE1 and AD/CE0 are used to select the channel.  The DRCTCE specifies the mode of the channel select.                                                                                                                                                                                                |
| C/D                                            | 25                                     | I   | The $C/\overline{D}$ defines the type of the data transfered between the CPU and the ZEN2044F(command or value). This pin is usually connected with LSB of the address lines.                                                                                                                                                                                                                                                                                                                           |
| RD                                             | 34                                     | I   | The $\overline{RD}$ is the strobe signal of the read operation.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| WR                                             | 33                                     | I   | The $\overline{WR}$ is the strobe signal of the write operation.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| LD0<br>LD1<br>LD2<br>LD3                       | 8<br>55<br>73<br>88                    | I   | The $\overline{\text{LD}n}$ transmits the 32bit data which is stored in the preload register to the up/down counter.                                                                                                                                                                                                                                                                                                                                                                                    |
| LT0<br>LT1<br>LT2<br>LT3                       | 9<br>56<br>74<br>89                    | I   | The $\overline{\text{LT}n}$ stores the 32bit data of the up/down counter into the latch register.                                                                                                                                                                                                                                                                                                                                                                                                       |
| D0<br>D1<br>D2<br>D3<br>D4<br>D5<br>D6<br>D7   | 36<br>37<br>38<br>39<br>42<br>43<br>44 | I/O | These pins are connected with CPU data bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| EXTB0<br>EXTB1<br>EXTB2<br>EXTB3               | 5<br>52<br>70<br>85                    | I/O | In Mode 0, $\overline{EXTBn}$ is used as a general purpose input $\underline{U}$ of which value can be read from the status register. In Mode 1, $\overline{EXTBn}$ is a programable output. One of the following three signals can be selected:  -The equal signal $B(\overline{EQBn})$ -The signal that indicates detecting an abnormal input( $\overline{INTAIn}$ ) -The hold equal signal $B(\overline{INTEQBn})$                                                                                   |

### **ZEN2044F**

| Name                                                                                                     | No.                                                                             | I/O | Function                                                                                                                                               |
|----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Z/CLR0<br>Z/CLR1<br>Z/CLR2<br>Z/CLR3                                                                     | 20<br>63<br>81<br>98                                                            | I   | The Z/CLR <i>n</i> clears the value of the up/down counter. This pin is usually connected with the index signal of a rotary encoder or a linear scale. |
| B/ <u>DN</u> 0<br>B/ <u>DN</u> 1<br>B/ <u>DN</u> 2<br>B/ <u>DN</u> 3                                     | 19<br>62<br>80<br>97                                                            | I   | The $B/\overline{DN}n$ is the count pulse input B or DN.                                                                                               |
| A/ <u>UP</u> 0<br>A/ <u>UP</u> 1<br>A/ <u>UP</u> 2<br>A/ <u>UP</u> 3                                     | 18<br>61<br>79<br>96                                                            | I   | The A/ $\overline{\text{UP}}n$ is the count pulse input A or UP.                                                                                       |
| SEL00<br>SEL01<br>SEL02<br>SEL10<br>SEL11<br>SEL12<br>SEL20<br>SEL21<br>SEL22<br>SEL30<br>SEL31<br>SEL32 | 10<br>11<br>12<br>57<br>58<br>59<br>75<br>76<br>77<br>92<br>93                  | I   | The condition of these three pins(SELn0, SELn1 and SELn2) specifies the counter operation mode. See the Table 4.                                       |
| DIR0<br>DIR1<br>DIR2<br>DIR3                                                                             | 22<br>65<br>83<br>3                                                             | I   | The DIR $n$ selects the count direction of the up/down counter.                                                                                        |
| UD/AB0<br>UD/AB1<br>UD/AB2<br>UD/AB3                                                                     | 21<br>64<br>82<br>2                                                             | I   | The UD/ $\overline{\mathrm{AB}}n$ selects the input pulse mode(up/down or not).                                                                        |
| Vss                                                                                                      | 4<br>15<br>24<br>32<br>40<br>46<br>49<br>51<br>66<br>72<br>78<br>87<br>90<br>95 | -   | Ground(0V)                                                                                                                                             |

### **ZEN2044F**

| Name                    | No.                                               | I/O | Function                                                       |
|-------------------------|---------------------------------------------------|-----|----------------------------------------------------------------|
| Vdd                     | 7<br>17<br>35<br>41<br>54<br>68<br>69<br>84<br>91 | -   | Supply voltage(+5V)                                            |
| N.C.                    | 1<br>14<br>23<br>31<br>50<br>60<br>100            | -   | Not connected.                                                 |
| TESTO<br>TEST1<br>TESTI | 47<br>48<br>13                                    | I   | These test pins MUST be connected with +5V in nomal operation. |

Note ) Except N.C., the input pins which are not used MUST be connected with Vdd or Ground.

#### 4. Operation

The opration of the ZEN2044F is controlled by the system software. To use this counter, it is necessary to specify "command words", "counter reference value(if necessary)" and "preloaded value(if necessary)". Since the entire control circuit woks synchronously, the operations about registers(i.e. data read/write, command write and status read) can be carried out even if the counter is working.

Each channel can be programed separately because the ZEN2044F has four fully independent sets of the counter and the registers.

#### 4-1. CPU Interface

The CPU can access the ZEN2044F with AD/ $\overline{\text{CE}}$ 3-0, C/ $\overline{\text{D}}$ ,  $\overline{\text{RD}}$  and  $\overline{\text{WR}}$ . The ZEN2044F has following two modes for selecting the target channel. The mode depends on DRCTCE.

### 4-1-1. Direct Channel Enable Mode(DRCTCE="1")

In this mode,  $AD/\overline{CE}n$  is used as the channel enable input for channel n. So multiple channels can be accessed at a time(write operation only).

Table 2

| DRCTCE | AD/CE3 | AD/CE2 | AD/CE1 | AD/CE0 | C/D | RD | WR | Function                          |
|--------|--------|--------|--------|--------|-----|----|----|-----------------------------------|
| 1      | 1      | 1      | 1      | 1      | *   | *  | *  | Disable(data bus: High-impedance) |
| 1      | 1      | 1      | 1      | 0      | 0   | 0  | 1  | Read: latch register(ch.0)        |
| 1      | 1      | 1      | 0      | 1      | 0   | 0  | 1  | Read: latch register(ch.1)        |
| 1      | 1      | 0      | 1      | 1      | 0   | 0  | 1  | Read: latch register(ch.2)        |
| 1      | 0      | 1      | 1      | 1      | 0   | 0  | 1  | Read: latch register(ch.3)        |
| 1      | *      | *      | *      | 0      | 0   | 1  | 0  | Write: data for registers(ch.0)   |
| 1      | *      | *      | 0      | *      | 0   | 1  | 0  | Write: data for registers(ch.1)   |
| 1      | *      | 0      | *      | *      | 0   | 1  | 0  | Write: data for registers(ch.2)   |
| 1      | 0      | *      | *      | *      | 0   | 1  | 0  | Write: data for registers(ch.3)   |
| 1      | 1      | 1      | 1      | 0      | 1   | 0  | 1  | Read: status register(ch.0)       |
| 1      | 1      | 1      | 0      | 1      | 1   | 0  | 1  | Read: status register(ch.1)       |
| 1      | 1      | 0      | 1      | 1      | 1   | 0  | 1  | Read: status register(ch.2)       |
| 1      | 0      | 1      | 1      | 1      | 1   | 0  | 1  | Read: status register(ch.3)       |
| 1      | *      | *      | *      | 0      | 1   | 1  | 0  | Write: command(ch.0)              |
| 1      | *      | *      | 0      | *      | 1   | 1  | 0  | Write: command(ch.1)              |
| 1      | *      | 0      | *      | *      | 1   | 1  | 0  | Write: command(ch.2)              |
| 1      | 0      | *      | *      | *      | 1   | 1  | 0  | Write: command(ch.3)              |

4-1-2. Normal Addressing Mode(DRCTCE="0") In this mode, A pair of AD/ $\overline{\text{CE}}$ 3 and AD/ $\overline{\text{CE}}$ 2 is used as the chip enable input for the ZEN2044F and the lower two bits(AD/ $\overline{\text{CE}}$ 1 and AD/ $\overline{\text{CE}}$ 0) specify the target channel.

Table 3

| DRCTCE | AD/CE3 | AD/CE2 | AD/CE1 | AD/CE0 | C/D | RD | WR | Function                          |
|--------|--------|--------|--------|--------|-----|----|----|-----------------------------------|
| 0      | 1      | 1      | *      | *      | *   | *  | *  | Disable(data bus: High-impedance) |
| 0      | 0      | 1      | *      | *      | *   | *  | *  | Disable(data bus: High-impedance) |
| 0      | 1      | 0      | *      | *      | *   | *  | *  | Disable(data bus: High-impedance) |
| 0      | 0      | 0      | 0      | 0      | 0   | 0  | 1  | Read: latch register(ch.0)        |
| 0      | 0      | 0      | 0      | 1      | 0   | 0  | 1  | Read: latch register(ch.1)        |
| 0      | 0      | 0      | 1      | 0      | 0   | 0  | 1  | Read: latch register(ch.2)        |
| 0      | 0      | 0      | 1      | 1      | 0   | 0  | 1  | Read: latch register(ch.3)        |
| 0      | 0      | 0      | 0      | 0      | 0   | 1  | 0  | Write: data for registers(ch.0)   |
| 0      | 0      | 0      | 0      | 1      | 0   | 1  | 0  | Write: data for registers(ch.1)   |
| 0      | 0      | 0      | 1      | 0      | 0   | 1  | 0  | Write: data for registers(ch.2)   |
| 0      | 0      | 0      | 1      | 1      | 0   | 1  | 0  | Write: data for registers(ch.3)   |
| 0      | 0      | 0      | 0      | 0      | 1   | 0  | 1  | Read: status register(ch.0)       |
| 0      | 0      | 0      | 0      | 1      | 1   | 0  | 1  | Read: status register(ch.1)       |
| 0      | 0      | 0      | 1      | 0      | 1   | 0  | 1  | Read: status register(ch.2)       |
| 0      | 0      | 0      | 1      | 1      | 1   | 0  | 1  | Read: status register(ch.3)       |
| 0      | 0      | 0      | 0      | 0      | 1   | 1  | 0  | Write: command(ch.0)              |
| 0      | 0      | 0      | 0      | 1      | 1   | 1  | 0  | Write: command(ch.1)              |
| 0      | 0      | 0      | 1      | 0      | 1   | 1  | 0  | Write: command(ch.2)              |
| 0      | 0      | 0      | 1      | 1      | 1   | 1  | 0  | Write: command(ch.3)              |

#### 4-2. Command mode

The ZEN2044F has the following two system modes. First of all, it is necessary to determine which mode you use(Mode 0 or Mode 1). The system mode is fixed by executing the system mode set command (90H or 91H).

### 4-2-1. Mode 0 [after executing command(90H) or system reset]

**EXTB***n* is set as a universal input terminal U. One set of the refrence register and the comparator is available.

### 4-2-2. Mode 1 [after executing command(91H)]

 $\overline{\text{EXTB}n}$  is set as an output terminal. Both  $\overline{\text{EXTA}n}$  and  $\overline{\text{EXTB}n}$  can be controlled by the instruction sets of Mode 1. And two sets of the refrence register and the comparator are available.

### 4-3. Selection of counter operation mode

The type of counter pulse and the mode of clearing counter by Z input depend on the condition of  $UD/\overline{AB}n$ , SELn0, SELn1 and SELn2 (these signals should be static and not set by the CPU). Refer to Table 4 for detail.

Table 4

| UD/ABn | SELn2 | SEL <i>n</i> 1 | SELn0 | Pulse input(Edge eval.) | Clear mode           |  |
|--------|-------|----------------|-------|-------------------------|----------------------|--|
| 1      | *     | *              | *     | Up/down pulse           | Asynchronous clear   |  |
|        | 0     | 0              | 0     | Phase-shifted(single)   |                      |  |
|        | 0     | 0              | 1     | Phase-shifted(double)   | Synchronous clear    |  |
|        | 0     | 1              | 0     | Phase-shifted(quad)     |                      |  |
| 0      | 1     | 0              | 0     | Phase-shifted(single)   |                      |  |
|        | 1     | 0              | 1     | Phase-shifted(double)   | Asynchronous clear   |  |
|        | 1     | 1              | 0     | Phase-shifted(quad)     |                      |  |
|        | 0     | 1              | 1     | Single pulse(single)    | A gymah nanaya alaan |  |
|        | 1     | 1              | 1     | Single pulse(double)    | Asynchronous clear   |  |

### 4-4. Pulse count timing(Edge evaluation)

The following diagrams show how an edge of the input pulse is evaluated in each count operation mode. "1" means counting and "0" means no operation.

### Up/down pulse input



Note ) Both  $\overline{UP}$  and  $\overline{DN}$  should not be "0" at once.

### Phase-shifted pulse input



### Single pulse input



Note ) B is used as the count enable signal.

#### 4-5. Detection of abnormal input

The ZEN2044F has the function to check whether the phase-shifted pulse inputs show a correct transition state(shown in Fig.1 with  $\iff$  mark) or not.

When an abnormal transition state(shown in Fig.1 with ←-- mark) occurs, the Abnormal Input flag(D7 bit of the status register) is set. Some causes of the abnormal transition state are as follows:

- (1) The frequencies of phase shifted pulse inputs exceed the one fourth of the system clock frequency. In this case, the transition state cannot be sampled correctly.
- (2) When the line-noises are sampled, the ZEN2044F detects the abnormal transition.

Fig.1 State transitions and an example of detecting the abnormal input



### 4-6. Default values of internal registers after reset

After  $\overline{RESET}$  is asserted, the values of the internal registers and the system mode are set according to Table 6.

Table 6

| Regsiter/Mode                                                              | The reset value                                                                                       | Regsiter/Mode       | The reset value                   |  |  |  |  |
|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|---------------------|-----------------------------------|--|--|--|--|
| Counter                                                                    | 000000Н                                                                                               | System mode         | Mode 0                            |  |  |  |  |
| Preload reg.                                                               | keeping the value<br>before reset                                                                     | Reference reg.<br>A | keeping the value<br>before reset |  |  |  |  |
| Latch reg.                                                                 | keeping the value<br>before reset                                                                     | Reference reg.<br>B | keeping the value<br>before reset |  |  |  |  |
| Command reg. D7(LD) D6(ZE1) D5(ZE0) D4(LT) D3(RS1) D2(RS0) D1(BS1) D0(BS0) | 0 — (NOP) 1                                                                                           |                     |                                   |  |  |  |  |
| Status reg. D7(AI) D6(Z) D5(A) D4(B) D3(DTR) D2(U/D) D1(EQA) D0(U)         | 0 Depending on input Z/CLR Depending on input A/UP Depending on input B/DN 0 0 1 Depending on input U |                     |                                   |  |  |  |  |

#### 5. Registers

The ZEN2044F has the following registers at each cannel.

A command register for controling the action of the counter.[write only]

A status register for indicating the internal state.[read only]

A preload register for storing the counter value to be loaded.[write only]

A reference register for storing the value to be compared with the counter.[write only]

A latch register for storing the counter value to be read by the CPU.[read only]

Note ) The counter value can be directly wrote without storing it in the preload register but we don't recommend it.

### 5-1. Access pointer

Before you write a data to a certain register, you should set an access pointer properly. But the ZEN2044F has an auto-incremental function of the access pointer. So when you write data in the following sequence, what you have to set is only a starting point. Also when reading the latch register, the target byte(low, middle or high) is changed automatically.

Fig.2 For writes Counter(low byte)[default at reset] Counter(middle byte) Counter(high byte) Reference reg.A(low byte) Reference reg.A(middle byte) Reference reg.A(high byte) Preload reg.(low byte) Preload reg.(middle byte) Preload reg.(high byte) In Mode 0 Reference reg.B(low byte) Reference reg.B(middle byte) Reference reg.B(high byte) In Mode 1 For reads Latch reg.(low byte)[default at reset] Latch reg.(middle byte) Latch reg.(high byte)

#### 5-2. System mode set command

This is the command word to select system mode. If you use the conter in Mode 1, you need to write the Mode 1 select command at first because the Mode 0 is the default setting at reset.

Table 6 Format of system mode set command

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | HeX | Operation              |
|----|----|----|----|----|----|----|----|-----|------------------------|
| 1  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 90  | Mode 0 select[default] |
| 1  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | 91  | Mode 1 select          |

#### (1) Mode 0[default]

 $\overline{\text{EXTA}n}$  is set as a comparator output  $(\overline{\text{EQA}n})$  and  $\overline{\text{EXTB}n}$  is set as a universal input U.

#### (2) Mode 1

 $\overline{\text{EXTB}n}$  is set as an output. Both  $\overline{\text{EXTA}n}$  and  $\overline{\text{EXTB}n}$  can be programed. Please refer to Mode1 register format in detail.

#### 5-3. Command register format(common to Mode 0 and Mode 1)

This is the command word for selecting register, selecting byte, latching counter, loading preloaded value and controling action of Z phase input.

Table 7 Field format of command register(common to Mode 0 and Mode 1)

| D7 | D6  | D5  | D4 | D3  | D2  | D1  | D0  |
|----|-----|-----|----|-----|-----|-----|-----|
| LD | ZE1 | ZE0 | LT | RS1 | RS0 | BS1 | BS0 |

#### BS1,BS0(Byte Select)

The registers(preload, reference and latch) and the up/down counter have 24 bit length but the CPU bus is 8 bit in the ZEN2044F. The BS1 and BS0 determine the target byte(high byte, middle byte or low byte) when the CPU accesses ZEN2044F.

#### RS1,RS0(Register Select)

RS1 and RS0 specify the register to be accessed from among the three registers(preload, reference and latch) and the up/down counter.

#### LT(Latch)

This bit is used to store the value of the up/down counter into the latch register.

#### ZE1, ZE0(Z phase input control)

ZE1 and ZE0 control the way of clearing the counter by Z phase input. One of "ignoring", "once" or "every time" can be selected.

#### LD(Load)

This bit is used to transmit the data which is stored in the preload register to the up/down counter.

#### Note 1)

Do not execute Load and Latch operations at once.

#### Note 2)

When Load or Latch command is executed, the external pins,  $\overline{LT}$  and  $\overline{LD}$ , must be fixed at "1".

| rar | oie 8 | Forma | t of c | ommand | register |
|-----|-------|-------|--------|--------|----------|
|     |       |       |        |        |          |
|     |       |       |        |        |          |

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Operation                                   |  |
|----|----|----|----|----|----|----|----|---------------------------------------------|--|
| *  | *  | *  | *  | 0  | 0  | *  | *  | Selecting up/down counter[default]          |  |
| *  | *  | *  | *  | 0  | 1  | *  | *  | Selecting reference reg. A                  |  |
| *  | *  | *  | *  | 1  | *  | *  | *  | Selecting preload reg.(in Mode 0)           |  |
| *  | *  | *  | *  | 1  | 0  | *  | *  | Selecting preload reg.(in Mode 1)           |  |
| *  | *  | *  | *  | 1  | 1  | *  | *  | Selecting reference reg. B(in Mode 1)       |  |
| *  | *  | *  | *  | *  | *  | 0  | 0  | Selecting low byte[default]                 |  |
| *  | *  | *  | *  | *  | *  | 0  | 1  | Selecting middle byte                       |  |
| *  | *  | *  | *  | *  | *  | 1  | *  | * Selecting high byte                       |  |
| *  | 0  | 0  | *  | *  | *  | *  | *  | Keeping current setting as to Z phase input |  |
| *  | 0  | 1  | *  | *  | *  | *  | *  | Setting Z phase pulse ineffective           |  |
| *  | 1  | 0  | *  | *  | *  | *  | *  | Setting only next Z phase pulse effective   |  |
| *  | 1  | 1  | *  | *  | *  | *  | *  | Setting every Z phase pulse effective       |  |
| 0  | *  | *  | 0  | *  | *  | *  | *  | No operation as to Load/Latch               |  |
| 0  | *  | *  | 1  | *  | *  | *  | *  | Latching the count value                    |  |
| 1  | *  | *  | 0  | *  | *  | *  | *  | Loading the preload value                   |  |
| 1  | 0  | 0  | 1  | *  | *  | *  | *  | Command ID                                  |  |
| 1  | *  | *  | 1  | *  | *  | *  | *  | Inhibit(except Command ID)                  |  |

Note 1)

"\*" stands for "don't care".

Note 2)

Command ID indicates system mode select or Mode 1 command.

#### 5-4. Command register format(Mode 1)

Only when the system mode is Mode 1, the command group of Mode 1 becomes effective. The reference register B can be accessed in Mode 1 only and the D0 of the status register shows the result of the comparator B.  $\overline{\text{EXTA}n}$  can be programmed to output one of three signals( $\overline{\text{EQA}n}$ ,  $\overline{\text{EQA}n}$  +  $\overline{\text{EQB}n}$  or  $\overline{\text{INTEQA}n}$ ).  $\overline{\text{EXTB}n}$  can be programmed to output one of three signals( $\overline{\text{EQB}n}$ ,  $\overline{\text{INTEQB}n}$  or  $\overline{\text{INTAIn}}$ ).

 $\overline{\text{EQA}n}$  is the result of comparing the reference register A to the up/down counter.

 $\overline{\mathrm{EQB}n}$  is the result of comparing the reference register B to the up/down counter.

 $\overline{\text{EQA}n+\text{EQB}n}$  is the logical sum(OR) of  $\overline{\text{EQA}n}$  and  $\overline{\text{EQB}n}$ .

 $\overline{\text{INTEQA}n}$  is the hold output of  $\overline{\text{EQA}n}$ .

 $\overline{\text{INTEQB}n}$  is the hold output of  $\overline{\text{EQB}n}$ .

<u>INTAI</u>*n* is holding low once an abnormal transition state is detected.

Above three hold outputs can be used for an interrupt  $\overline{\text{request.}}$  And they have three functions, enabling, disabling and reset. AI reset command resets  $\overline{\text{EXTB}n}$  output and initializes the phase discrimination circuit.

Table 9 Format of command register(mode1)

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | HEX | Operation                                                                             |
|----|----|----|----|----|----|----|----|-----|---------------------------------------------------------------------------------------|
| 1  | 0  | 0  | 1  | 0  | 0  | 1  | 0  | 92  | Inhibit                                                                               |
| 1  | 0  | 0  | 1  | 0  | 0  | 1  | 1  | 93  | Inhibit                                                                               |
| 1  | 0  | 0  | 1  | 0  | 1  | 0  | 0  | 94  | $\overline{\text{EQA}n} + \overline{\text{EQB}n} \rightarrow \overline{\text{EXTA}n}$ |
| 1  | 0  | 0  | 1  | 0  | 1  | 0  | 1  | 95  | $\overline{\text{EQA}n} \rightarrow \overline{\text{EXTA}n}$ [default]                |
| 1  | 0  | 0  | 1  | 0  | 1  | 1  | 0  | 96  | Inhibit                                                                               |
| 1  | 0  | 0  | 1  | 0  | 1  | 1  | 1  | 97  | $\overline{\text{EQB}n} \rightarrow \overline{\text{EXTB}n}$ [default]                |
| 1  | 0  | 0  | 1  | 1  | 0  | 0  | 0  | 98  | INTEQAn command reset                                                                 |
| 1  | 0  | 0  | 1  | 1  | 0  | 0  | 1  | 99  | $\overline{\text{INTEQB}n}$ , $\overline{\text{INTAI}n}$ command reset                |
| 1  | 0  | 0  | 1  | 1  | 0  | 1  | 0  | 9A  | $\overline{\text{INTAI}n} \rightarrow \overline{\text{EXTB}n}$ disabling              |
| 1  | 0  | 0  | 1  | 1  | 0  | 1  | 1  | 9B  | $\overline{\text{INTAI}n} \rightarrow \overline{\text{EXTB}n}$ enabling               |
| 1  | 0  | 0  | 1  | 1  | 1  | 0  | 0  | 9C  | $\overline{\text{INTEQA}n} \rightarrow \overline{\text{EXTA}n}$ disabling             |
| 1  | 0  | 0  | 1  | 1  | 1  | 0  | 1  | 9D  | $\overline{\text{INTEQA}n} \rightarrow \overline{\text{EXTA}n}$ enabling              |
| 1  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 9E  | $\overline{\text{INTEQB}n}$ -> $\overline{\text{EXTB}n}$ disabling                    |
| 1  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 9F  | $\overline{\text{INTEQB}n} \rightarrow \overline{\text{EXTB}n}$ enabling              |

Note ) Both  $\overline{EXTAn}$  and  $\overline{EXTBn}$  cannot share an interrupt line with outputs of other IC because they don't have 3st output.

### 5-5. Status register

The status register is used to monitor internal conditions. Please refer to "4-1. CPU Interface" for the method of reading out this register.

Table 10 Format of status register

| Bit | Symbol          | Active | Description                                                                                                                                                                                 |
|-----|-----------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D7  | AI              | High   | Abnormal input detection flag(only phase-shifted pulse input) A value of "1" indicates that the abnormal transition state of phase shifted inputs is detected.                              |
| D6  | Z               | None   | Z/CLR <i>n</i> input monitor  This bit indicates the value of Z/CLR <i>n</i> input that is sampled at the rising edge of CLK.                                                               |
| D5  | A               | None   | $A/\overline{UPn}$ input monitor  This bit indicates the value of $A/\overline{UPn}$ input that is sampled at the rising edge of CLK.                                                       |
| D4  | В               | None   | $\overline{B/\overline{DNn}}$ input monitor This bit indicates the value of $\overline{B/\overline{DNn}}$ input that is sampled at the rising edge of CLK.                                  |
| D3  | DTR             | High   | Data ready flag of the latch register  A value of "1" indicates the counter data has been transfered to the latch register. This flag is cleared by reading the data of the latch register. |
| D2  | U/D             | None   | Direction of counting  The current counting direction is indicated. "1" means up count and "0" means down count.                                                                            |
| D1  | EQA             | Low    | Coincident flag of comparator A A value of "0" indicates the data of counter and comparator A is coincident.                                                                                |
| D0  | U<br>[Mode 0]   | None   | Universal input $U(\overline{EXTBn})$ input monitor This bit indicates the value of $\overline{EXTBn}$ input. This signal is not sampled but directly monitored.                            |
|     | EQB<br>[Mode 1] | Low    | Coincident flag of comparator B A value of "0" indicates the data of counter and comparator B is coincident.                                                                                |

### **ZEN2044F**

### 6. Internal timing(for reference only)

The internal timings of the ZEN2044F are as follows.

#### Note)

CNT stands for the value of the internal counter.

LDR stands for the value of the preload register.

LTR stands for the value of the latch register.

CMPRA stands for the value of the reference register A.

### 6-1. Counting up/down

### 6-1-1. Two phase-shifted pulse mode(DIR="1")



### 6-1-2. Single pulse mode(DIR="1")



### 6-1-3. Up/down pulse mode(DIR="1")



### 6-2. Clearing counter

6-2-1. Asynchronous mode(Detecting the rising edge of Z/CLR)



6-2-2. Synchronous mode(Detecting the rising or falling edge of A/UP when Z/CLR is "1" and B/DN is "0")



### 6-3. Loading or latching counter value

### 6-3-1. External loading or latching



### 6-4. Detecting coincidence

### 6-4-1. Momentary coincident output



### 6-4-2. Hold coincident output



Note)

 $\overline{\text{EXTB}}$  has the same timing as  $\overline{\text{EXTA}}$  in Mode 1.

### 7. Electrical specifications

### 7-1. Absolute maximum ratings

| Parameter           | Symbol | Rating          | Unit |
|---------------------|--------|-----------------|------|
| Supply voltage      | Vdd    | -0.3 to +7.0    | V    |
| Input voltage       | Vin    | -0.3 to VDD+0.3 | V    |
| Output voltage      | Vout   | -0.3 to VDD+0.3 | V    |
| Input current       | Iin    | -10 to +10      | mA   |
| Storage temperature | Tstg   | -40 to +125     | °C   |

### 7-2. Recommended operating conditions

| Parameter             | Symbol | Min  | Тур  | Max  | Unit |
|-----------------------|--------|------|------|------|------|
| Supply voltage        | Vdd    | 4.75 | 5.00 | 5.25 | V    |
| Operation temperature | Topr   | 0    | -    | +70  | °C   |

### 7-3. DC chracteristics(at the recomended operating conditions)

| Parameter             | Symbol | Conditions     | Min | Max | Unit |
|-----------------------|--------|----------------|-----|-----|------|
| Input "High" voltage  | Vih    |                | 2.2 |     | V    |
| Input "Low" voltage   | Vil    |                |     | 0.8 | V    |
| Input "High" current  | Iih    | Vin=Vdd        | -10 | 10  | uA   |
| Input "Low" current   | Iil    | Vin=Vss        | -10 | 10  | uA   |
| Output "High" voltage | Voh    | Ioh=-4mA       | 2.4 |     | V    |
| Output "Low" voltage  | Vol    | Iol=4mA        |     | 0.4 | V    |
| Standby current       | Idds   | Vin=Vdd or Vss |     | 17  | uA   |
| Operation current     | Iddo   |                |     | 60  | mA   |

Note)

Ioh is Output "High" current and Iol is Output "Low" current.

### 7-4. AC chracteristics

| Parameter                                                                | Symbol            | Min                | Max | Unit |
|--------------------------------------------------------------------------|-------------------|--------------------|-----|------|
| $\overline{\text{C/D}}, \overline{\text{AD/CE}}n$ setup time(to D7-D0)   | Taw               | 0                  |     | nS   |
| $C/\overline{D}$ , $AD/\overline{CE}n$ hold time(to D7-D0)               | $T_{\text{WA}}$   | 0                  |     | nS   |
| Data setup time(to WR)                                                   | $T_{\text{DW}}$   | 30                 |     | nS   |
| Data hold time(to WR)                                                    | $T_{\mathrm{WD}}$ | 3                  |     | nS   |
| WR pulse width                                                           | Tww               | 25                 |     | nS   |
| WR recovery time[1]                                                      | Twrc              | Tcy*5              |     | nS   |
| $C/\overline{D}$ , $AD/\overline{CE}n$ setup time(to RD)                 | Tar               | 0                  |     | nS   |
| $C/\overline{D}$ , $AD/\overline{CE}n$ hold time(to RD)                  | $T_{RA}$          | 5                  |     | nS   |
| RD pulse width                                                           | $T_{\text{RR}}$   | 25                 |     | nS   |
| Data access time(from RD)                                                | $T_{\mathrm{RD}}$ |                    | 20  | nS   |
| Data float time(from RD)                                                 | $T_{\mathrm{DF}}$ | 4                  |     | nS   |
| RD recovery time[1]                                                      | Trrc              | Tcy*5              |     | nS   |
| Clock high/low pulse width                                               | Тср               | 15                 |     | nS   |
| Clock cycle time                                                         | Тсч               | 30                 |     | nS   |
| Reset pulse width                                                        | $T_{	ext{RST}}$   | Tcy*2              |     | nS   |
| Reset recovery time                                                      | Trsrc             | $T_{\text{CY}}^*5$ |     | nS   |
| LDn pulse width                                                          | $T_{\text{LDW}}$  | 25                 |     | nS   |
| TTn pulse width                                                          | Tltw              | 25                 |     | nS   |
| EXTBn set time(from CLK)[2]                                              | Tseb              |                    | 15  | nS   |
| EXTBn float time(from CLK)[3]                                            | $T_{	ext{FEB}}$   |                    | 15  | nS   |
| $\overline{\text{EXTA}n}$ , $\overline{\text{EXTB}n}$ fix time(from CLK) | $T_{EXF}$         |                    | 15  | nS   |
| $A/\overline{UP}n$ , $B/\overline{DN}n$ cycle time[4]                    | Тсчав             | Tcy*4+32           |     | nS   |
| $A/\overline{UP}n$ , $B/\overline{DN}n$ high/low level time[4]           | $T_{PWAB}$        | Tcy*2+16           |     | nS   |
| $A/\overline{UP}n$ , $B/\overline{DN}n$ phase difference time[4]         | Tsab              | Тсү+8              |     | nS   |
| Z/CLRn high level width[5]                                               | Tsz               | Tcy+8              |     | nS   |
| Z/CLRn pulse width[6]                                                    | Tzz               | Tcy+8              |     | nS   |
| $A/\overline{\text{UP}}n$ setup time(to $B/\overline{\text{DN}}n$ )[7]   | Tss               | Tcy+8              |     | nS   |
| $A/\overline{\mathrm{UP}}n$ high/low level time[7]                       | Tahl              | Tcy+8              |     | nS   |
| $A/\overline{\text{UP}}n$ cycle time[7]                                  | Tacy              | Tcy*2+16           |     | nS   |
| $A/\overline{UP}n$ , $B/\overline{DN}n$ cycle time[8]                    | Tudcy             | Tcy*2+16           |     | nS   |
| $A/\overline{UP}n$ , $B/\overline{DN}n$ high/low level time[8]           | Tu                | Tcy+8              |     | nS   |

### Note)

- [1] Required interval clock cycles to access the ZEN2044F
- [2] At executing Mode 1 select command
- [3] At executing Mode 0 select command
- [4] Two phase-shfted pulse mode
- [5] Synchronous clear mode
- [6] Asynchronous clear mode
- [7] Single pulse mode
- [8] Up/down pulse mode

### 7-5. Timing diagrams

### 7-5-1. Two phase-shifted pulse input timing



### 7-5-2. Single pulse input timing



### 7-5-3. Up/down pulse input timing



### 7-5-4. Write cycle timing



### 7-5-5. Read cycle timing



### 7-5-6. System clock timing



### 7-5-7. System reset timing



# 7-5-8. Load pulse input timing



### 7-5-9. Latch pulse input timing



### 7-5-10. $\overline{\mathsf{EXTA}n}$ , $\overline{\mathsf{EXTB}n}$ output timing



Note)

At executing Mode 1 select command  $(\overline{EXTBn})$  is changed from input into output)



Note)

At executing Mode 0 select command( $\overline{EXTB}n$  is changed from output into input)

### 8. Package Outlines



#### Note

This document is the user manual for the ZEN2044F and all information is applicable for reference only. Copying the whole contents or any part of this document is strictly prohibited.

ZENIC reserves the right to change or alter this information or prices of specfied products at any time without any notice. ZENIC advises its customers to obtain the latest version of device specifications.

ZENIC does not assume any liability arising out of the application or use of any product or circuit described herein; nor does it convey any license under its patent right or the rights of others.

ZENIC products are not designed, intended, or authrized for use as componets in systems intended for surgical implant into the body, or other applications inteded to support or sustain life, or for any other application in which the failure of the ZENIC products could create a situation where personal injury or death may occur.

All rights reserved. Copyright 2000 ZENIC Inc.



ZENIC Inc. URL http://www.zenic.co.jp/ 1-17-14, Ogaya Otsu Shiga 520-2144, JAPAN Fax. +81-77-543-9431 Phone. +81-77-543-2101 E-mail support@zenic.co.jp